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Description of the Related Art 

A number of different types of data structures may be used in a computing system for 
storing information for which access time, including updates and retrievals of the stored 
information, is critical. These data structures include linked lists, hash tables, and tree structures. 
Tree structures in particular are often used as a technique for optimizing the number of operations 
that must be performed to locate a particular item within an ordered file system or database. 

A number of different types of tree structures are known in the art, including binary trees, 
m-way trees, AVL trees (named for Adelson-Velskii and Landis, who introduced them), radix 
trees, B-trees, B*-trees, BMrees, tries, and so forth. In binary trees, each node has at most two 
child nodes. AVL trees are also commonly referred to as height-balanced binary trees, which 
means that any subtree within the AVL tree is no more than one level deeper on its left (or right) 
side than it is on the right (or left) side. Radix trees are trees in which a search progresses based 
on a composite of the information found in the nodes. B-trees are height-balanced m-way trees, 
where an m-way tree is a search tree that has at most some number "m" entries in each node of 
the tree. B*-trees, B'-trees, and tries are all variations of B-trees. The particular nuances of these 
varying types of trees are not critical to an understanding of the present invention, and thus will 
not be described in further detail. (For a detailed discussion of these types of tree structures, 
reference may be made to 'Tundamentals of Data Structures", E. Horowitz and S. Sahni, 
published by Computer Science Press, Inc. (1976), pp. 422 - 549.) 



It is desirable to balance a tree in order to assure an optimal and consistent worst-case 
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cost in terms of the number of tree accesses that are required for locating a particular item (or, 
conversely, for determining that the particular item does not exist in the tree). As nodes are 
inserted into a balanced tree and deleted therefrom, it is necessary to re-balance the tree in order 
that the advantageous properties of the balanced tree are maintained. Algorithms for keeping 
trees in balance are known in the art. Typically, such algorithms tend to be complex and costly in 
terms of execution time. Furthermore, a re-balancing operation may result in decreased system 
performance because the tree cannot be used for productive accesses while the re-balancing is 
being performed. 

When using tree structures on multi-programming operating systems that support 
concurrent execution by multiple threads, it is quite likely that one or more threads will try to 
access a particular tree for the purpose of retrieving already-stored data at the same time that one 
or more other threads tries to access the tree for updating (i.e. inserting, deleting, or changing) 
information. To ensure that the retrieval threads do not collide with the update threads and 
thereby return invalid or corrupted results to the requesting processes, serialization techniques are 
typically used to control the order in which the threads access the tree. When running in a multi- 
processor (MP) environment having a symmetric MP operating system (such as the OS/390® 
operating system from the International Business Machines Corporation ("IBM")) wherein the 
computing task is shared among multiple central processing units, the serialization task becomes 
especially difficult. ("OS/390" is a registered trademark of IBM.) 



One technique commonly used in the prior art for providing serialized access to tree 
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structures is locking. Typically, threads or tasks that need only to retrieve information (referred 
to herein as "search tasks" or "searchers") obtain a shared lock before using a tree, where a 
shared lock enables more than one search task (i.e. all those sharing the lock) to retrieve 
information at the same time. Tasks that need to update information, on the other hand, typically 
obtain an exclusive lock. While a task has an exclusive lock on a tree, no other update tasks nor 
any search tasks can access the tree. Instead, those tasks are typically suspended while waiting 
for the currently-active update process to complete and release the exclusive lock, at which time 
the suspended tasks will be resumed. Thus, while locking provides the necessary serialization, it 
does so at a very high cost in terms of performance overhead. For very busy systems such as 
super servers, the expense of this type of locking approach leads to very serious performance 
degradation. 

Tree structures are commonly used in the routing tables of routers and gateways (referred 
to hereinafter as routers, for ease of reference), as a means for quickly evaluating the Internet 
Protocol (IP) address in a data packet in order to determine how to route the packet while 
providing an acceptable level of performance and throughput. As link speeds are increasing, the 
number of IP packets which a router is required to process per second is becoming very high. If 
an exclusive lock is held on a routing table implemented using a tree structure, then all data 
transfers and forwarding must stop until the lock is released. Operations on trees may require a 
significant amount of programming logic, and expenditure of a significant amount of computing 
time for rebalancing trees (as well as for traversing the trees to find a particular route). As will be 
obvious, it is very undesirable for the data transfers and forwarding to be halted even for relatively 
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short periods of time, and thus it is desirable to optimize the tree operations. 

Another technique commonly used in the prior art for providing serialized access to tree 
structures is to minimize the time spent in the locked status by not actually re-structuring or re- 
balancing the trees each time an update is performed. In this approach, deleted nodes are not 
5 completely removed until some predetermined number of deletes have been processed — or 

perhaps until a predetermined amount of time has elapsed. When this number of deletes occurs or 
S this amount of time elapses, an exclusive lock is obtained, suspending all search tasks as the 

[p. 

f; restructuring occurs. In some extreme cases, the entire tree may need to be rebuilt. In the 

interim, while it is not yet time to restructure the tree, the deleted nodes are simply marked as 

hi 

r vi* 

40 deleted or invalid. A serious disadvantage of this approach is that each task using the tree must 

[3 check each node it accesses to determine whether that node is still valid, which significantly 

JSJ increases the access time of the task. 

"Serialization of AVL-Binary Tree Element Retrieval via Duplexed Pointers", IBM 
Technical Disclosure Bulletin, No. 10B, pp. 138 - 139 (March 1992) discloses a technique for 

15 serializing AVL trees without requiring locks for retrieval tasks. In this technique, the tree header 
contains an active tree indicator, a synchronization count, and a duplexed pair of pointers to the 
first tree element. Each node in the tree contains a key, a user data field or pointer thereto, a 
duplexed pair of left child pointers and a duplexed pair of right child pointers, and a duplexed pair 
of balance indicators. Retrieval operations use the active tree indicator to know which of the set 

20 of left and right child pointers to use (i.e. the "active" pointers); update operations use the 
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opposite ones of these pointers (i.e. the "inactive" pointers). Each time an update is performed, 
the synchronization count in the tree header is incremented and the active tree indicator is 
switched. The values are stored in adjacent storage so that a single atomic action can be used for 
the increment and switch, ensuring that both are performed simultaneously. Prior to performing a 
retrieval, these values are saved. After the retrieval operation occurs, the saved values are 
compared to the values currently stored in the tree header. If they are identical, the retrieval ends 
normally. Otherwise, when they are different, this is a sign that the retrieval occurred from a 
now-obsolete version of the tree, and the retrieve operation must be re-done until the 
synchronization count and active tree indicator values have not changed. Updates are made to the 
inactive tree, without regard to whether searchers are still using the tree. This may have 
catastrophic results in some cases (e.g. when an update operation deletes a pointer that a search 
task is looking at.) This disclosure states that the storage for any node that was once part of the 
tree cannot be freed, as this will cause the retrieve operation to fail; instead, storage that is no 
longer needed for a node (e.g. because the node has been deleted or has been replaced by another 
node during an update process) is pooled and may be reused as part of the tree. 

Commonly-assigned U. S. Patent 5,089,952, which is entitled 6C Method for Allowing 
Weak Searchers to Access Pointer-Connected Data Structures Without Locking", teaches a 
technique for avoiding use of locks while still ensuring that the content of the tree remains in a 
correct state. (A ct weak searcher", as defined therein, is an access task that has no intent of 
updating the stored information.) Update operations first lock the "scope" of a node, using prior 
art techniques which are not described for determining the scope (where the scope is defined as 
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the path from a "deepest safe node" — i.e. a node that will not overflow or underflow during an 
update — to a leaf of the tree). The disclosed technique retains deleted nodes and nodes which 
have become redundant while performing insertions, where these deleted and redundant nodes are 
referred to as "disconnected nodes", until one of several defined criteria has been met. In one 
solution, time stamps are used, where each searcher keeps track of how long it has been using the 
tree and compares this duration to a predetermined time period. If the search is not completed 
within this time period, it must be aborted and restarted. In a second solution, either a range and 
level value are added to each node in the tree and searchers must evaluate this range and level as 
they traverse each node, or a creation time is added to each node and searchers must check this 
creation time value. In either case, the search may need to be aborted and restarted, depending on 
the result of the comparison. In a third solution, a unique object identifier is added to each node, 
and this identifier must be checked during the search using one of the techniques from the second 
solution to determine whether the search must be restarted. The patent states that, in each of the 
three solutions, searchers will occasionally be required to restart their search unnecessarily. While 
the disclosed technique provides advantages over the prior art, the need to repeat searches as well 
as the need to perform additional operations to check the validity of nodes during the searching 
process add to the overhead of performing searches. 

It would be preferable to use a serialization approach that minimizes use of locks (and 
thereby minimizes the resulting suspension of tasks) yet still guarantees that search results are 
valid and does not require searches to be re-started. Furthermore, it is desirable that the 
serialization approach has good performance characteristics and that it allows storage to be 
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readily freed and re-used. The solution should preferably be extendable to other types of data 
structures, in addition to trees. The manner in which the present invention satisfies these 
objectives is described herein. 

SUMMARY OF THE INVENTION 

An object of the present invention is to provide a technique for serializing data structure 
retrieval and update that minimizes use of locks yet still guarantees that search results are valid 
and does not require searches to be re-started. 

Yet another object of the present invention is to provide this technique in a manner that 
does not require use of time stamps or validity checks by searchers as they traverse through a data 
structure. 

A further object of the present invention is to provide this technique in a manner that 
enables re-use of freed storage. 

Another object of the present invention is to provide this technique wherein the data 
structure is a tree (such as a B-tree). 

Other objects and advantages of the present invention will be set forth in part in the 
description and in the drawings which follow and, in part, will be obvious from the description or 
may be learned by practice of the invention. 
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To achieve the foregoing objects, and in accordance with the purpose of the invention as 
broadly described herein, the present invention provides a computer program product, a system, 
and a method for serializing data structure retrievals and updates. In one aspect, this technique 
comprises: creating two identical tree structures, each representing an initial state for accessing 
stored data; performing searches against a first of the two trees; performing a first update against 
a second of the two trees, yielding a revised tree; switching the first tree and the revised tree, such 
that the first tree becomes the second tree and the revised tree becomes the first tree; performing, 
after the switching step, a second update against the second tree, yielding a synchronized tree that 
is structurally identical to the first tree; and performing subsequent searches against the first tree. 

The technique preferably further comprises obtaining an exclusive lock prior to performing 
the first update and releasing the exclusive lock after performing the second update and the 
switching. Atomic transactions are preferably used to maintain proper synchronization between 
the first tree and the second tree. Performing the first update may further comprise queuing a 
transaction, in which case performing the second update further comprises applying the queued 
transaction against the second tree that results from the switching. The technique may further 
comprise performing a subsequent update against the synchronized tree that results from 
performing the second update, which causes repeating the switching of trees. 

In another aspect, this technique comprises: maintaining two trees, a first of which is used 
for one or more concurrent searches and a second of which is used for an update operation; 
switching the two trees after performing the update operation; and synchronizing the two trees 
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such that both reflect the update operation. 

In yet another aspect, this technique comprises: maintaining two data structures, a first of 
which is used for one or more concurrent searches and a second of which is used for an update 
operation; switching the two data structures after performing the update operation; and 
synchronizing the two data structures such that both reflect the update operation. The two data 
structures may be, for example, B-trees. 

The present invention will now be described with reference to the following drawings, in 
which like reference numbers denote the same element throughout. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a diagram of a networked computing environment in which the present 
invention may be practiced; 

Figures 2A - 2C provide examples of the control blocks and data structures that may be 
operated upon by the present invention; and 

Figures 3 and 4 provide flowcharts which set forth logic that may be used to implement 
the preferred embodiment of the present invention. 
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DESCRIPTION OF THE PREFERRED EMBODIMENT 

Fig. 1 illustrates a data processing network 40 in which the present invention may be 
practiced. The data processing network 40 may include a plurality of individual networks, such as 
wireless network 42 and network 44, each of which may include a plurality of individual 
workstations 10. One or more routers (not shown) are typically used to route traffic among 
networks. Additionally, as those skilled in the art will appreciate, one or more LANs may be 
included (not shown), where a LAN may comprise a plurality of intelligent workstations coupled 
to a host processor. 

Still referring to Fig. 1, the networks 42 and 44 may also include mainframe computers or 
servers, such as a gateway computer 46 or application server 47 (which may access a data 
repository 48). A gateway computer 46 serves as a point of entry into each network 44. The 
gateway 46 may be preferably coupled to another network 42 by means of a communications link 
50a. The gateway 46 may also be directly coupled to one or more workstations 10 using a 
communications link 50b, 50c. The gateway computer 46 and/or server 47 may be implemented 
utilizing an Enterprise Systems Architecture/370 available from IBM, an Enterprise Systems 
Architecture/390 ("ESA/390") computer, etc. Depending on the application, a midrange 
computer, such as an Application System/400 (also known as an AS/400) may be employed. 
('"Enterprise Systems Architecture/370" is a trademark of IBM; '"Enterprise Systems 
Architecture/390", "Application System/400", and "AS/400" are registered trademarks of IBM.) 
These are merely representative types of computers with which the present invention may be used. 
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The gateway computer 46 may also be coupled 49 to a storage device (such as data 
repository 48). Further, servers such as gateway 46 and application server 47 may be coupled to 
other servers (not shown in Fig. 1). 

Those skilled in the art will appreciate that the gateway computer 46 may be located a 
great geographic distance from the network 42, and similarly, the workstations 10 may be located 
a substantial distance from the networks 42 and 44. For example, the network 42 may be located 
in California, while the gateway 46 may be located in Texas, and one or more of the workstations 
10 may be located in New York. The workstations 10 may connect to the wireless network 42 
using a networking protocol such as the Transmission Control Protocol/Internet Protocol 
('TCP/IP") over a number of alternative connection media, such as cellular phone, radio 
frequency networks, satellite networks, etc. The wireless network 42 preferably connects to the 
gateway 46 using a network connection 50a such as TCP or UDP (User Datagram Protocol) over 
IP, X.25, Frame Relay, ISDN (Integrated Services Digital Network), PSTN (Public Switched 
Telephone Network), etc. The workstations 10 may alternatively connect directly to the gateway 
46 using dial connections 50b or 50c. Further, the wireless network 42 and network 44 may 
connect to one or more other networks (not shown), in an analogous manner to that depicted in 



In the preferred embodiment, the present invention is implemented in computer software, 
although a solution implemented partly or entirely in hardware is also within the scope of the 
present invention. When implemented in software, the programming code which embodies the 



Fig. 1. 
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present invention is typically accessed by a computing device such as a router, a user workstation, 
or a server or gateway (such as gateway 46 and/or server 47) from long-term storage media of 
some type, such as a CD-ROM drive or hard drive. The software programming code may be 
embodied on any of a variety of known media for use with a data processing system, such as a 
diskette, hard drive, or CD-ROM. The code may be distributed on such media, or may be 
distributed from the memory or storage of one computer system over a network of some type to 
other computer systems for use by such other systems. Alternatively, the programming code may 
be embodied in the memory of the appropriate device. The techniques and methods for 
embodying software programming code in memory, on physical media, and/or distributing 
software code via networks are well known and will not be further discussed herein. 

The devices on which the present invention may be used advantageously include a client 
device, server, or intermediary device in a network, as well as a standalone device that is not 
operating as part of a network. Or, the software may execute on multiple devices in a distributed 
manner, or it may operate simultaneously on multiple processors in an MP operating system such 
as OS/390. (As an example of operating on multiple devices, the search algorithm disclosed 
herein may operate primarily on client devices which first obtain the relevant bit settings to be 
used in the search algorithm from code executing on a central server.) When used in a 
networking environment, an implementation of the present invention may be executing in a Web 
environment, where a Web server provides services in response to requests from clients connected 
through the Internet. Alternatively, an implementation of the present invention may be executing 
in a non-Web environment (using the Internet, a corporate intranet or extranet, or any other type 
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of network). Configurations for the networking environment include a client/server network, as 
well as a peer-to-peer environment. These environments and configurations are well known in the 
art. For ease of reference, the preferred embodiment will be described hereinafter in terms of 
operations that occur on a single computing device. 

The present invention provides a reliable and efficient technique for serializing access to 
data structures. This serialization technique will be discussed herein in terms of serializing access 
to tree data structures, although this is for purposes of illustration and not of limitation. 
Alternatively, this technique may be used with other data structures (including, but not limited to, 
hash tables) for providing optimal serialized access. 

The technique of the present invention provides improved serialization for access to tree 
structures by using reference counts (also referred to herein as ct use counts") to keep track of 
whether a search tree is in use and by using atomic instructions for updating and checking 
particular values. These atomic instructions are used for synchronizing the data structure access 
processes in order to guarantee valid search results. The atomic instructions used in the preferred 
embodiment are Load Multiple (LM), which is used to load values into two registers at the same 
time; Compare and Swap (CS), which compares two 4-byte values; and Compare Double and 
Swap, which compares two 8-byte values. These atomic operations are described herein in terms 
of their definition in the IBM ESA/390 Principles of Operation manual. It will be obvious to one 
of ordinary skill in the art that these particular instructions are meant to be representative of the 
function to be accomplished: equivalent techniques may be used in place of the described 
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instructions, provided that the necessary atomicity of operation is maintained. 

The LM instruction requires three parameters. The first parameter is a register to be used 
as the starting location of the load operation, and the second is a register to be used as the ending 
location. The third parameter points to the beginning storage/focation of the value(s) to be loaded 
into the registers. Both the CD and CDS comparison instructions require three parameters. The 
first and second parameters are pointers to the values being compared. The third parameter is a 
pointer to a new value that will be copied in place of the value addressed by the second pointer if 
the first and second values are equal; otherwise, when the values are not equal, the value pointed 
to by the second pointer is copied into thp location addressed by the first pointer. (Note that 
Compare and Swap is the technique nrentioned in the previously-discussed IBM Technical 
Disclosure Bulletin article for perprming atomic updates on AVL trees.) 

The preferred embodiment of the present invention will now be described in more detail 
with reference to Figs. 2 through 4. 

The technique of the present invention requires little extra storage beyond that used by the 
tree nodes. In particular, no time stamps, counts, or attribute values are added to the nodes of the 
tree. Instead, a tree control block is used along with two trees that are always present. The two 
trees are identical at any time when there are no updates occurring. The control block is 
described in more detail below with reference to Fig. 2 A. The present invention uses a lock (an 
exclusive lock) for serializing update tasks, but does not use locks for those tasks that only 
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perform searches and retrieve results without altering stored data. Therefore, search tasks will 
never suspend for purposes of serializing access. The disclosed technique also guarantees that the 
search tree is valid at all times, and thus there will never be a time when a searcher needs to re- 
search the tree because an update has happened: when the searcher finds a result, it can reliably 
use this result without further validity comparisons. Furthermore, the use of reference counts as 
disclosed herein enables completely (and safely) removing from the tree any nodes that are no 
longer needed and freeing the storage that was used by those nodes. 

Fig. 2A illustrates the format of a control block 200 that may be used to implement the 
present invention. Note that use of the term "control block" is not meant to imply any particular 
implementation technique. In addition, the fields shown therein may be altered without deviating 
from the scope of the present invention. (For example, the order of the fields may be changed, 
provided that those fields which are operated upon jointly by the atomic operations remain 
properly co-located.) 

In the preferred embodiment, the control block 200 comprises: (1) a use count 205; (2) 
an indication bit 210; (3) a wait bit 215; and (4) an identifier 220 of a waiting thread, which may 
be null if no thread is currently waiting. Preferably, each of the trees has its own separate copy of 
control block 200 which is stored in the tree root's control block so that obtaining access to a 
particular tree provides access to the bit settings and use count for that tree. 

te present invention will now be briefly summarized. Following 
-16- 




The novel technique 
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this summary, the algorithms which may be used to impterjient this technique will be described 
with reference to Figs. 3 and 4. As stated above^t^o trees exist at all times. Fig. 2B illustrates 
how two pointer values 225, 230 are us£d"m the present invention to point to the two trees 245, 
250. According to the preferre^mbodiment, these pointer values are stored in contiguous 
storage 240 so that both values can be retrieved and set with a single atomic LM instruction. 
Every node in the ty/o trees has a pointer to its twin node in the other tree, as is shown in Fig. 2C 
using pairs o£iines of various styles. It is not necessary that these twin pointers reside in 
contigq0us storage. 

At any point in time, one of the trees is being used for searching while the other is 
dedicated to update operations. For ease of reference, the tree in which searches are conducted is 
referred to herein as "treel", while the update tree is referred to as "tree2" Multiple tasks may be 
executing searches against treel at the same time, but only one update at a time can be made 
against tree2. If there are no updates being made, then treel and tree2 are identical, and all 
searches proceed against treel . When an update request is processed, the update is made to 
tree2, and a very fast switching operation is then performed so that the just-updated tree becomes 
the tree to be searched (i.e. the new treel). New searchers then enter this new treel . Once any 
searchers that were still in the process of using the old treel that has been switched to become 
tree2 complete their searches, this now out-of-date tree2 is then revised to bring it into alignment 
with treel . The technique for revising the new tree2 is also very fast and efficient: no tree 
traversals are required to find the nodes to be updated. Instead, while the original update is being 
processed against tree2 (the tree2 that becomes treel after the switch), entries are placed on a 
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transaction queue. These entries are pointers to the twin of the nodes that were changed in tree2, 
and thus represent the actions that must be taken to carry out this particular update on treel after 
treel and tree2 are switched. Once the switch takes place, the recorded (i.e. queued) transactions 
are simply played back against the new tree2, enabling it to very quickly come back into alignment 
with the tree that is actively being searched (treel). 

Note that each pair of twin nodes points to the same underlying data (except, of course, 
for brief periods when the trees may be out of alignment during an update). Thus, use of two 
trees requires very little extra storage. For example, when the present invention is being used 
with network routing tables, there need be only one copy of each route entry, where that route 
entry is then pointed to by both of the trees. 

The logic that is preferably used by the search process of the preferred embodiment is 
depicted in Fig. 3. This process begins at Block 305, where a determination is made as to which 
of the two trees is currently treel (i.e. the tree to be used for searches). This determination is 
preferably made using an LM instruction, which loads the tree pointers (see Fig. 2B) in a 
particular order. In the preferred embodiment, the pointer to the search tree is always loaded 
into the first register (or perhaps simply a first storage area, if an atomic load technique other than 
LM is used) and the pointer to the update tree is always loaded into the second register (or a 
second storage area). The pointer to treel is retrieved from this first register and stored for use 
during the search algorithm. 
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A copy of the remaining values from treel 5 s control block (see Fig. 2A) is obtained next, 
and the use count for treel is then incremented and an attempt is made to store the incremented 
value (along with the other fields of the control block) using a CDS (Block 3 1 0). When using a 
CDS instruction having the three parameters described above, the order of parameters for this 
increment operation is: (1) the value copied from the control block in Block 310; (2) the value of 
the control block as incremented; and (3) the current value of the control block. Block 315 tests 
to see whether this increment operation failed. For example, suppose the values copied from the 
control block are (5, 0, 0, 0, ...), indicating that five searchers are already using treel. The 
current search task increments this value to 6. If the CDS determines that the current control 
block for treel no longer contains a use count of 5, then the number of active searchers has 
changed. The value may already be 6, for example, indicating that some other new search task 
has already updated the control block. Or, the value may be 4, indicating that one of the active 
search tasks has ended. In any case, the current search task cannot update the control block when 
the use count does not match because to do so would corrupt the use count value. Thus, the use 
count value must be obtained anew, and the increment operation retried.. To determine whether 
the trees have been switched before attempting the increment again, processing continues from 
Block 3 1 5 to Block 320 which tests whether the tree pointers match. The pointer to treel that 
was copied during operation of Block 305 is compared to the first tree pointer currently stored in 
the control block (see element 225 of Fig. 2B). If these pointer values do not match, then the 
search algorithm is not pointing to the correct treel, and control returns to Block 305 to re-load 
the pointers and begin again. (This mismatch between pointers typically occurs because the 
update process has switched treel and tree2.) If the pointer values do still match, then it is not 
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necessary to re-load the pointers; control simply returns to Block 310 to attempt the increment 
operation again. (Note that the incremented value computed in Block 3 10 has not been stored in 
control block 200 when the CDS fails, according to the way in which the CDS instruction 
operates, and thus repeatedly iterating these logic blocks does not introduce an error situation.) 

The test in Block 315 may yield a positive result in other situations besides changes to the 
use count. For example, the value of the indication bit may have changed between the time when 
the control block values are copied and when the CDS operation is attempted, indicating that the 
update process (depicted in Fig. 4) is switching treel and tree2. Changes of this type also cause 
processing to transfer to Block 320 to determine whether the trees have been switched. 

The test in Block 3 1 5 has a negative result when the values in treel 's current control 
block are still what the current search task expects them to be. Processing therefore continues to 
Block 330 where the search is performed using treel. Note that in the case where a search task is 
processing while an update is also processing, the logic in Blocks 305 through 320 ensures that 
the search task will find the correct tree against which its search is to be performed. 

At Block 335, the use count for treel is decremented using a CDS operation. The 
parameters of this CDS are: (1) a value that is retrieved from the tree's control block; (2) the 
decremented value; and (3) the tree's current control block values. Block 340 then tests to see if 
the use count resulting from this decrement is zero. If so, then this search task was the last active 
searcher using this tree, and processing continues to Block 345 which checks to see if the wait bit 
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in the current control block is set. If it is, then the update thread has been suspended while 
waiting for the searchers to finish using this tree (and the tree they are searching is now actually 
tree2, because they were in the middle of searching the tree when the trees were switched). In 
this case, the suspended update thread is located using the stored pointer (see element 220 of Fig. 
2 A), and that thread is awoken (Block 350). The processing of Fig. 3 then ends for this search 
task. 

Returning now to the description of Block 340, if this test has a negative result, then there 
are still active searchers using this tree (which may have been switched and is now actually tree2), 
and thus processing must bypass the wake-up operation in Block 350. The wake-up operation is 
also bypassed when the test in Block 345 has a negative result, indicating that there is no 
suspended update thread. 

Fig. 4 depicts the logic that is preferably used to implement the update process of the 
preferred embodiment. At Block 405, a determination is made as to which of the two trees is 
currently tree2 (i.e. the tree to be used for updates), preferably using an LM instruction (as 
described above with reference to Block 305 of Fig. 3). The pointer to tree2 is retrieved and 
stored for use during the update algorithm. An exclusive lock is then obtained on tree2 (Block 
410), using any suitable locking technique (such as binary semaphores). 

At Block 415, the actual update operation is performed using tree2. Note that this 
update operation is unaffected by the presence of search tasks operating on treel . The tree 
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traversal and modification information used in making this particular update to tree2 is stored on a 
transaction queue (Block 420) for later replay against treel . For example, suppose the update 
requires locating a particular node of the tree and then deleting that node. If the node to be 
deleted is element 255 of Fig. 2B, then in the preferred embodiment the queued transaction 
generally comprises (1) a record to change node 265 so that its left branch will point to an 
updated node that replaces node 270, and (2) a record to delete node 270, which is node 255's 
twin. While a number of complex, computationally expensive tree traversal operations may be 
required in determining the steps to take when performing the original update against tree2 , the 
subsequent updates that will be performed (at Block 460, after the trees are switched) to the tree 
that is now treel will omit all of those expensive determinations because of the identical structure 
of the trees and the existence of the queued transaction (and its use of the twin pointers). 

After the update has been performed and the update transaction is queued, the indication 
bit for treel is set on (Block 425) to indicate that an update of the search tree is needed. 
Preferably, a CS instruction is used for this purpose, and operates on the first four bytes of treel's 
control block. Note that this bit setting will cause newly-arriving search tasks to avoid beginning 
their search until after the switch is complete, by operation of the logic of Block 315 of Fig. 3. 

In Block 430, the trees are switched, so that the newly-updated tree becomes the tree to 
be used for "new" searches and so that the "old" search tree can now be updated to match it. 
Preferably, this switch process comprises reordering the tree pointers 235, 240 using a CDS 
instruction, so that these reordered values will be obtained by subsequent LM instructions. 
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The logic of Blocks 435 through 445 is designed to handle searchers leaving the tree that 
has just become tree2. Block 435 checks the use count for tree2. If the use count is not greater 
than zero, then there are no active searchers and the test in Block 435 has a negative result. 
Control therefore transfers to Block 455. On the other hand, when there are still active searchers 
using what is now tree2, then the use count is greater than zero and control reaches Block 440 
where a CDS instruction is used to set tree2's wait bit and to store a pointer to the current update 
thread into the control block. (Setting the wait bit indicates that a searcher is still using this 
tree2.) After this CDS instruction is performed, the test in Block 445 checks to see whether the 
use count of the CDS matches the value that this update process expects. If it did not, then a 
searcher has just finished using tree2, so control transfers back to Block 435 to determine whether 
this was the final active searcher. Otherwise, when the use count matches what the update task 
expects, there has been no change in the number of active searchers and thus the update thread is 
preferably suspended for the time being (Block 450). In this case, the wait bit in tree2's control 
block has been set by the successful CDS instruction of Block 440, and the update thread will 
remain suspended until it is awakened by the final active searcher reaching the logic of Block 350 
of Fig. 3. 

The test in Block 455 asks whether the update thread is currently suspended. This test is 
shown in Fig. 4 as repeating until a negative result occurs. As will be obvious to one of skill in 
the art, this depiction is meant to show that processing does not continue on to Block 460 unless 
the update thread is no longer suspended. In an actual implementation, this would typically be 
accomplished by using operations such as a wait and a subsequent signal on a semaphore, rather 
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than a constantly repeating loop. Thus, a negative result for the test in Block 455 occurs 
following the awakening of the suspended update thread, or when the thread did not suspend 
because there were no active searchers using tree2. In either case, control reaches Block 460 
which performs the updates against the current tree2 by playing back the queued transaction (as 
discussed above with reference to Block 420). At this point, the two trees are again 
synchronized. Block 465 turns off the wait bit and the indication bit in tree2's control block, in 
preparation for enabling subsequent update operations to access tree2. The exclusive lock held by 
the update thread is then released (Block 470), and the processing for this update ends. Each 
subsequent update executes the logic of Fig. 4, causing another switch of the trees as has been 
described. 

As has been demonstrated, the present invention defines an efficient technique for 
serializing access to data structures while ensuring that the contents of the data structure are 
valid. This occurs without requiring searchers to perform compute-intensive comparison 
operations to determine validity and without requiring searchers to use locks on the data 
structure. Empirical results of evaluations that have been conducted show that the cost of 
retrieving and updating information using this technique is approximately 50 percent less than the 
cost of using prior art techniques. Furthermore, in prior art solutions that use only a single tree, 
the exclusive locking process that is required for performing an update operation causes a very 
large spike in storage consumption as searchers become suspended awaiting completion of the 
update (and release of the lock), where this suspension requires information for the searchers to 
be stored. In addition, as additional search requests are generated in these prior art systems, 
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additional threads are typically created to handle the new requests because the existing threads are 
all blocked (i.e. suspended). However, these new threads will quickly become blocked as well, 
further increasing the storage consumption. With the present invention, on the other hand, search 
threads do not suspend and thus do not cause this type of spike in storage space. Only update 
tasks suspend, and at any given time there is likely to be only one such suspended update task (if 
any) due to the efficient technique with which updates are carried out when using the present 
invention. 

The disclosed technique may be used advantageously for many applications in which 
searches must be guaranteed accurate search results and in which rapid processing of data 
structure updates is necessary. As an example, these techniques may be used for optimizing 
performance of data structures used for network routing. 

While the preferred embodiment of the present invention has been described, additional 
variations and modifications in that embodiment may occur to those skilled in the art once they 
learn of the basic inventive concepts. In particular, while the preferred embodiment has been 
described in terms of accessing tree structures, the inventive concepts of the present invention 
may be applied advantageously to other types of data structures as well Therefore, it is intended 
that the appended claims shall be construed to include both the preferred embodiment and all such 
variations and modifications as fall within the spirit and scope of the invention. 
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